<!-- 我的 日志 页面 -->
<template>
	<view class="my-journal-container-box">
		<view class="my-journal-top-box">
			<!-- 当我的日志为空时显示的页面 -->
			<data-null tipText="暂无日志" v-if="journalDataList.length < 1"></data-null>
			<!-- 日志不为空时显示的页面 -->
			<view class="my-journal-nonull-box" v-else>
				<!-- 循环渲染日志数据列表 -->
				<block v-for="journalItem in journalDataList" :key="journalItem.type_id">
					<view class="my-journal-item" @click="journalItemClick(journalItem.type_id, journalItem.type_name)">
						<view>
							<text class="case-type">{{ journalItem.type_name }}</text>
							<text>共{{ journalItem.total }}个案件</text>
						</view>
						<u-icon name="arrow-right"></u-icon>
					</view>
				</block>
			</view>
		</view>
		<!-- 底部的添加日志按钮 -->
		<view class="add-journal-box" @click="addJorunalClick">添加日志</view>
	</view>
</template>

<script>
export default {
	data() {
		return {
			// 日志数据列表
			journalDataList: []
		};
	},
	onLoad() {
		this.getData()
	},
	// 在 onShow() 生命周期函数中读取 vuex 中的 openId,如果读取到则用户已登录
	onShow() {
		if(this.vuex_isSubmit) {	// 刷新数据
			this.getData()
			this.$u.vuex('vuex_isSubmit', false)
		}
	},
	methods: {
		async getData() {
			const res = await this.$u.utils.login()
			if(!res) return
			const data = await this.$u.api.getJournalCategory()
			if(!data) return
			this.journalDataList = data
			console.log(this.journalDataList);
		},
		// 添加日志按钮的点击事件(先在此进行用户权限验证即用户是否已经登录，已登录才有此权限)
		async addJorunalClick() {
			// 验证用户是否登录
			const result = await this.$u.utils.login();
			// 返回为 true 则用户通过身份认证，则跳转到 添加日志 页面
			if (result) {
				uni.navigateTo({
				 url: '/myPackageA/pages/views/add-journal' // 跳转到添加案例页面
				});
			}
		},
		// 我的日志项的点击事件(跳转到对应日志查看页)
		journalItemClick(type_id, case_name) {
			this.$u.route(`/myPackageA/pages/views/case-teyp-sum?type_id=${type_id}&case_name=${case_name}`);
		}
	}
};
</script>

<style lang="scss" scoped>
.my-journal-container-box {
	width: 750rpx;
	min-height: 100vh;
	background-color: #f5f5f5;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}
.my-journal-top-box {
	min-height: calc(100vh - 90rpx);
}

.add-journal-box {
	height: 90rpx;
	line-height: 90rpx;
	text-align: center;
	background-color: $u-text-color;
	font-size: 32rpx;
	font-family: PingFang SC;
	font-weight: 500;
	color: #ffffff;
}
.my-journal-nonull-box {
	padding-top: 20rpx;
}
.my-journal-item {
	height: 92rpx;
	padding: 0 24rpx;
	// box-shadow: 0px 1px 0px 0px #E8E8E8;
	border-bottom: 1rpx solid #e8e8e8;
	background-color: white;
	display: flex;
	justify-content: space-between;
	align-items: center;
	color: #999999;
	font-size: 30rpx;
	font-family: PingFang SC;
	font-weight: 500;
}
.case-type {
	color: #141418;
	margin-right: 2em;
}
</style>
